home *** CD-ROM | disk | FTP | other *** search
/ Chip 1998 September / CHIP Eylül 1998.iso / Slackwar / docs / Sound-HOWTO < prev    next >
Text File  |  1997-11-03  |  76KB  |  1,828 lines

  1.   The Linux Sound HOWTO
  2.   Jeff Tranter, jeff_tranter@pobox.com
  3.   v1.18, 1 November 1997
  4.  
  5.   This document describes sound support for Linux. It lists the sup¡
  6.   ported sound hardware, describes how to configure the kernel drivers,
  7.   and answers frequently asked questions. The intent is to bring new
  8.   users up to speed more quickly and reduce the amount of traffic in the
  9.   Usenet news groups and mailing lists.
  10.  
  11.   1.  Introduction
  12.  
  13.   This is the Linux Sound HOWTO. It is intended as a quick reference
  14.   covering everything you need to know to install and configure sound
  15.   support under Linux. Frequently asked questions about sound under
  16.   Linux are answered, and references are given to some other sources of
  17.   information on a variety of topics related to computer generated sound
  18.   and music.
  19.  
  20.   The scope is limited to the aspects of sound cards pertaining to
  21.   Linux. See the other documents listed in the References section for
  22.   more general information on sound cards and computer sound and music
  23.   generation.
  24.  
  25.   1.1.  Acknowledgments
  26.  
  27.   Much of this information came from the documentation provided with the
  28.   sound driver source code, by Hannu Savolainen (hannu@voxware.pp.fi).
  29.   Thanks go to Hannu and the many other people who developed the Linux
  30.   kernel sound drivers and utilities.
  31.  
  32.   Thanks to the SGML Tools package, this HOWTO is available in several
  33.   formats, all generated from a common source file.
  34.  
  35.   1.2.  Revision History
  36.  
  37.      Version 1.1
  38.         first version; posted to SOUND channel of Linux activists
  39.         mailing list only
  40.  
  41.      Version 1.2
  42.         minor updates; first version available on archive sites
  43.  
  44.      Version 1.3
  45.         converted to SGML; now available in several formats using Matt
  46.         Welsh's Linuxdoc-SGML tools; appearance changed due to new
  47.         format, only minor changes to content
  48.  
  49.      Version 1.4
  50.         minor tweaking of SGML; added answer on PAS16 and Adaptec1542A
  51.         SCSI adaptor incompatibilities
  52.  
  53.      Version 1.5
  54.         2.5a sound driver is now in 1.1 kernel distribution; note on
  55.         GUS-MAX support; other minor updates
  56.      Version 1.6
  57.         added info on "no space on device" error; added note that
  58.         Hacker's Guide is in a "hidden" directory; added question on
  59.         bidirectional mode; info on "device busy" errors; other minor
  60.         changes
  61.  
  62.      Version 1.7
  63.         added info on ASP and AWE32; VoxWare 2.9 is available; answer to
  64.         question on using IRQ2; references to Sound and SCSI HOWTOs
  65.  
  66.      Version 1.8
  67.         added question on errors under DOS; many minor things updated to
  68.         match the version 2.90 sound driver; info on DOOM; answer on
  69.         reducing noise
  70.  
  71.      Version 1.9
  72.         questions on recording and clone cards
  73.  
  74.      Version 1.10
  75.         mentioned that HOWTO is available on WWW, as printed copies, and
  76.         translations; info on DMA conflict with QIC tape driver; info on
  77.         Sound Galaxy NX Pro and Logitech BusMouse
  78.  
  79.      Version 1.11
  80.         A long overdue update (I've been busy); document placed under
  81.         GPL; brought up to date with version 3.0 sound driver; info on
  82.         many new supported sound card drivers; more info on
  83.         configuration and troubleshooting; lots of HTML links added;
  84.         brought in line with format of CD-ROM HOWTO
  85.  
  86.      Version 1.12
  87.         new sound drivers in 1.3.34 kernel; new sound device names; 1542
  88.         address is 334 not 333; clarify status of Creative Labs Emu and
  89.         ASP; pointer to Creative Labs and MediaTrix Web sites
  90.  
  91.      Version 1.13
  92.         note on the name VoxWare; updated to reflect latest supported
  93.         sound cards and configuration options; question on Plug and Play
  94.         support; question on block size problem; new xconfig and
  95.         menuconfig options; modutils has sound device support; vger
  96.         mailing list going away; emphasize author's Web site; other
  97.         miscellaneous minor changes
  98.  
  99.      Version 1.14
  100.         Audio Excell DSP16 is not currently supported (should be working
  101.         again in a few months); changes to configure program; Italian
  102.         version of HOWTO available; trick for setting mixer gains when
  103.         loading sound module; latest stable kernel is now 2.0; new name
  104.         for sound driver; question on root permissions on sound device
  105.         files
  106.  
  107.      Version 1.15
  108.         removed some questions that were very old and now obsolete; new
  109.         e-mail address for author; fixed some links to point to latest
  110.         software packages; more information on multimedia book; minor
  111.         spelling and grammatical changes
  112.  
  113.      Version 1.16
  114.         many updates and corrections from Hannu Savolainen; added six
  115.         month "best before" date; new URL to web page for book; added
  116.         link to Spanish translation; minor spelling and grammatical
  117.         changes
  118.  
  119.      Version 1.17
  120.         Chinese version available; alternate GUS driver; packet radio
  121.         modem; Linux Multimedia guide is now available in French and
  122.         Japanese; references to a couple of relevant mini-HOWTOs;
  123.         pointer for IBM ThinkPad
  124.  
  125.      Version 1.18
  126.         Korean translation available; more information on status of
  127.         sound on MIPS; updated info on multiple sound card support;
  128.         should be root when running fuser
  129.  
  130.   1.3.  New versions of this document
  131.  
  132.   New versions of this document will be periodically posted to the
  133.   comp.os.linux.answers newsgroup. They will also be uploaded to various
  134.   anonymous ftp sites that archive such information including
  135.   <ftp://sunsite.unc.edu/pub/Linux/docs/HOWTO/>.
  136.  
  137.   Hypertext versions of this and other Linux HOWTOs are available on
  138.   many World-Wide-Web sites, including  <http://sunsite.unc.edu/LDP/>.
  139.   Most Linux CD-ROM distributions include the HOWTOs, often under the
  140.   /usr/doc directory, and you can also buy printed copies from several
  141.   vendors. Sometimes the HOWTOs available from CD-ROM vendors, ftp
  142.   sites, and printed format are out of date. If the date on this HOWTO
  143.   is more than six months in the past, then a newer copy is probably
  144.   available on the Internet.
  145.  
  146.   A French translation of this document is available at
  147.   <ftp://ftp.ibp.fr/pub2/linux/french/docs/HOWTO/>.
  148.  
  149.   A Japanese translation is available from  <http://yebisu.ics.es.osaka-
  150.   u.ac.jp/linux/>.
  151.  
  152.   An Italian translation is available from
  153.   <http://www.psy.unipd.it/ildp/docs/HOWTO/Sound-HOWTO.html>.
  154.  
  155.   A Spanish translation is available from
  156.   <http://www.insflug.nova.es/howtos/online/sonido/sonido-COMO.html>.
  157.  
  158.   A Chinese translation is available from
  159.   <http://linux.ntcic.edu.tw/~yorkwu/linux/howto/sound/>.
  160.  
  161.   A Hangul (Korean) translation is available from
  162.   <http://members.iWorld.net/mangchi/HOWTO/Sound-HOWTO.html>.
  163.  
  164.   Most translations of this and other Linux HOWTOs can also be found at
  165.   <http://sunsite.unc.edu/pub/Linux/docs/HOWTO/translations/> and
  166.   <ftp://sunsite.unc.edu/pub/Linux/docs/HOWTO/translations/>.
  167.  
  168.   If you make a translation of this document into another language, let
  169.   me know and I'll include a reference to it here.
  170.  
  171.   1.4.  Feedback
  172.  
  173.   I rely on you, the reader, to make this HOWTO useful. If you have any
  174.   suggestions, corrections, or comments, please send them to me,
  175.   jeff_tranter@pobox.com, and I will try to incorporate them in the next
  176.   revision.
  177.  
  178.   I am also willing to answer general questions on sound cards under
  179.   Linux, as best I can. Before doing so, please read all of the
  180.   information in this HOWTO, and send me detailed information about the
  181.   problem. Please do not ask me about using sound cards under operating
  182.   systems other than Linux.
  183.  
  184.   If you publish this document on a CD-ROM or in hardcopy form, a
  185.   complimentary copy would be appreciated. Mail me for my postal
  186.   address. Also consider making a donation to the Linux Documentation
  187.   Project to help support free documentation for Linux. Contact the
  188.   Linux HOWTO coordinator, Greg Hankins  <mailto:gregh@sunsite.unc.edu>,
  189.   for more information.
  190.  
  191.   1.5.  Distribution Policy
  192.  
  193.   Copyright 1995-1997 Jeff Tranter.
  194.  
  195.   This HOWTO is free documentation; you can redistribute it and/or
  196.   modify it under the terms of the GNU General Public License as
  197.   published by the Free Software Foundation; either version 2 of the
  198.   License, or (at your option) any later version.
  199.  
  200.   This document is distributed in the hope that it will be useful, but
  201.   without any warranty; without even the implied warranty of
  202.   merchantability or fitness for a particular purpose.  See the GNU
  203.   General Public License for more details.
  204.  
  205.   You can obtain a copy of the GNU General Public License by writing to
  206.   the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139,
  207.   USA.
  208.  
  209.   2.  Sound Card Technology
  210.  
  211.   This section gives a very cursory overview of computer audio
  212.   technology, in order to help you understand the concepts used later in
  213.   the document. You should consult a book on digital audio or digital
  214.   signal processing in order to learn more.
  215.  
  216.   Sound is an analog property; it can take on any value over a
  217.   continuous range. Computers are digital; they like to work with
  218.   discrete values. Sound cards use a device known as an Analog to
  219.   Digital Converter (A/D or ADC) to convert voltages corresponding to
  220.   analog sound waves into digital or numeric values which can be stored
  221.   in memory. Similarly, a Digital to Analog Converter (D/A or DAC)
  222.   converts numeric values back to an analog voltage which can in turn
  223.   drive a loudspeaker, producing sound.
  224.  
  225.   The process of analog to digital conversion, known as sampling,
  226.   introduces some error. Two factors are key in determining how well the
  227.   sampled signal represents the original. Sampling rate is the number of
  228.   samples made per unit of time (usually expresses as samples per second
  229.   or Hertz). A low sampling rate will provide a less accurate
  230.   representation of the analog signal. Sample size is the range of
  231.   values used to represent each sample, usually expressed in bits. The
  232.   larger the sample size, the more accurate the digitized signal will
  233.   be.
  234.  
  235.   Sound cards commonly use 8 or 16 bit samples at sampling rates from
  236.   about 4000 to 44,000 samples per second. The samples may also be
  237.   contain one channel (mono) or two (stereo).
  238.  
  239.   FM Synthesis is an older technique for producing sound. It is based on
  240.   combining different waveforms (e.g. sine, triangle, square).  FM
  241.   synthesis is simpler to implement in hardware that D/A conversion, but
  242.   is more difficult to program and less flexible. Many sound cards
  243.   provide FM synthesis for backward compatibility with older cards and
  244.   software. Several independent sound generators or voices are usually
  245.   provided.
  246.  
  247.   Wavetable Synthesis combines the flexibility of D/A conversion with
  248.   the multiple channel capability of FM synthesis. With this scheme
  249.   digitized voices can be downloaded into dedicated memory, and then
  250.   played, combined, and modified with little CPU overhead. State of the
  251.   art sound cards all support wavetable synthesis.
  252.  
  253.   Most sound cards provide the capability of mixing, combining signals
  254.   from different input sources and controlling gain levels.
  255.  
  256.   MIDI stands for Musical Instrument Digital Interface, and is a
  257.   standard hardware and software protocol for allowing musical
  258.   instruments to communicate with each other. The events sent over a
  259.   MIDI bus can also be stored as MIDI files for later editing and
  260.   playback. Many sound cards provide a MIDI interface. Those that do not
  261.   can still play MIDI files using the on-board capabilities of the sound
  262.   card.
  263.  
  264.   MOD files are a common format for computer generated songs.  As well
  265.   as information about the musical notes to be played, the files contain
  266.   digitized samples for the instruments (or voices). MOD files
  267.   originated on the Amiga computer, but can be played on other systems,
  268.   including Linux, with suitable software.
  269.  
  270.   3.  Supported Hardware
  271.  
  272.   This section lists the sound cards and interfaces that are currently
  273.   supported under Linux. The information here is based on the latest
  274.   Linux kernels, at time of writing.
  275.  
  276.   The sound driver has its own version numbering. The latest stable
  277.   Linux kernel release was version 2.0.31, using sound driver version
  278.   3.5.4-960630.
  279.  
  280.   The author of the sound driver, Hannu Savolainen, typically also makes
  281.   available newer beta releases of the sound driver before they are
  282.   included as part of the standard Linux kernel distribution. The most
  283.   up to date list of supported cards is available at <http://www.4front-
  284.   tech.com/ossfree/new_cards.html> (USA) or
  285.   <http://personal.eunet.fi/pp/voxware/new_cards.html> (Europe). These
  286.   pages indicate which sound driver version is required for a given type
  287.   of sound card or if support for it is still under development. The
  288.   file /usr/src/linux/drivers/sound/Readme.cards distributed with the
  289.   kernel sound driver contains information on supported cards but it is
  290.   not always up to date.
  291.  
  292.   The information in this HOWTO is valid for Linux on the Intel
  293.   platform.
  294.  
  295.   The sound driver should also work with most sound cards on the Alpha
  296.   platform. However, some cards may conflict with I/O ports of other
  297.   devices on Alpha systems even though they work perfectly on i386
  298.   machines, so in general it's not possible to tell if a given card will
  299.   work or not without actually trying it.
  300.  
  301.   At the time of writing the sound driver was not yet working on the
  302.   PowerPC version of Linux, but it should be supported in future.
  303.  
  304.   Sound can be configured into the kernel under the MIPs port of Linux,
  305.   and some MIPs machines have EISA slots and/or built in sound hardware.
  306.   I'm told the Linux-MIPs group is interested in adding sound support in
  307.   the future.
  308.  
  309.   The Linux kernel includes a separate driver for the Atari and Amiga
  310.   versions of Linux that implements a compatible subset of the sound
  311.   driver on the Intel platform using the built-in sound hardware on
  312.   these machines.
  313.  
  314.   The SPARC port of Linux does not currently have sound support. Like
  315.   the Amiga and Atari, SPARC machines have built in sound hardware, so
  316.   it could be done with a new driver (this is somewhat ironic, as under
  317.   Linux /dev/dsp emulates the SunOS sound device).
  318.  
  319.   3.1.  Sound Cards
  320.  
  321.   The following sound cards are supported by the Linux kernel sound
  322.   driver:
  323.  
  324.   ╖  ATI Stereo F/X (no longer manufactured)
  325.  
  326.   ╖  AdLib (no longer manufactured)
  327.  
  328.   ╖  Ensoniq SoundScape (and compatibles made by Reveal and Spea)
  329.  
  330.   ╖  Gravis Ultrasound
  331.  
  332.   ╖  Gravis Ultrasound ACE
  333.  
  334.   ╖  Gravis Ultrasound Max
  335.  
  336.   ╖  Gravis Ultrasound with 16 bit sampling option
  337.  
  338.   ╖  Logitech Sound Man 16
  339.  
  340.   ╖  Logitech SoundMan Games
  341.  
  342.   ╖  Logitech SoundMan Wave
  343.  
  344.   ╖  MAD16 Pro (OPTi 82C928, 82C929, 82C930, 82C924 chipsets)
  345.  
  346.   ╖  Media Vision Jazz16
  347.  
  348.   ╖  MediaTriX AudioTriX Pro
  349.  
  350.   ╖  Microsoft Windows Sound System (MSS/WSS)
  351.  
  352.   ╖  Mozart (OAK OTI-601)
  353.  
  354.   ╖  Orchid SW32
  355.  
  356.   ╖  Personal Sound System (PSS)
  357.  
  358.   ╖  Pro Audio Spectrum 16
  359.  
  360.   ╖  Pro Audio Studio 16
  361.  
  362.   ╖  Pro Sonic 16
  363.  
  364.   ╖  Roland MPU-401 MIDI interface
  365.  
  366.   ╖  Sound Blaster 1.0
  367.  
  368.   ╖  Sound Blaster 16
  369.  
  370.   ╖  Sound Blaster 16ASP
  371.  
  372.   ╖  Sound Blaster 2.0
  373.  
  374.   ╖  Sound Blaster AWE32
  375.  
  376.   ╖  Sound Blaster Pro
  377.  
  378.   ╖  TI TM4000M notebook
  379.  
  380.   ╖  ThunderBoard
  381.  
  382.   ╖  Turtle Beach Tropez ("classic" but not Plus)
  383.  
  384.   ╖  Turtle Beach Maui
  385.  
  386.   ╖  Yamaha FM synthesizers (OPL2, OPL3 and OPL4)
  387.  
  388.   ╖  6850 UART MIDI Interface
  389.  
  390.   It should be noted that Plug and Play (PnP) sound cards are not fully
  391.   compatible with the older non-PnP models of the same device. For
  392.   example, the SoundBlaster16 PnP is not fully compatible with the
  393.   original SoundBlaster16. The same is true for the Soundscape PnP and
  394.   GUS PnP cards. More information related to Plug and Play is found
  395.   later in this document.
  396.  
  397.   The following cards are not supported, either because they are
  398.   obsolete or because the vendor will not release the programming
  399.   information needed to write a driver:
  400.  
  401.   ╖  Pro Audio Spectrum (original)
  402.  
  403.   ╖  Pro Audio Spectrum+
  404.  
  405.   ╖  older (Sierra Aria based) sound cards made by Diamond
  406.  
  407.   Other sound cards that are claimed to be compatible with one of the
  408.   supported sound cards may work if they are hardware (i.e. register
  409.   level) compatible.
  410.  
  411.   Even though most sound cards are claimed to be "SoundBlaster
  412.   compatible", very few currently sold cards are compatible enough to
  413.   work with the Linux SoundBlaster driver. These cards usually work
  414.   better using the MSS/WSS or MAD16 driver. Only real SoundBlaster cards
  415.   made by Creative Labs, which use Creative's custom chips (e.g.
  416.   SoundBlaster16 Vibra), MV Jazz16 and ESS688/1688 based cards generally
  417.   work with the SoundBlaster driver. Trying to use a "SoundBlaster Pro
  418.   compatible 16 bit sound card" with the SoundBlaster driver is usually
  419.   just a waste of time.
  420.  
  421.   The Linux kernel supports the SCSI port provided on some sound cards
  422.   (e.g. ProAudioSpectrum 16) and the proprietary interface for some CD-
  423.   ROM drives (e.g. Soundblaster Pro). See the Linux SCSI HOWTO and CDROM
  424.   HOWTO documents for more information.
  425.  
  426.   A loadable kernel module to support joystick ports, including those
  427.   provided on some sound cards, is also available.
  428.  
  429.   Note that the kernel SCSI, CD-ROM, joystick, and sound drivers are
  430.   completely independent of each other.
  431.  
  432.   For the latest information on the sound card driver check Hannu
  433.   Savolainen's World-Wide Web site listed in the References section.
  434.  
  435.   3.2.  Alternate Sound Drivers
  436.  
  437.   There are some "unofficial" sound drivers available, not included in
  438.   the standard Linux kernel distribution, and used in place of the
  439.   standard sound driver.
  440.  
  441.   A commercial version of the Linux sound driver is sold by 4Front
  442.   Technologies. It offers a number of additional features over the free
  443.   version included in the Linux kernel. For more information see the
  444.   4Front Technologies Web page at  <http://www.4front-tech.com/>.
  445.  
  446.   Markus Mummert (mum@mmk.e-technik.tu-muenchen.de) has written a driver
  447.   package for the Turtle Beach MultiSound (classic), Tahiti, and
  448.   Monterey sound cards. The documentation states:
  449.  
  450.        "It is designed for high quality hard disk record¡
  451.        ing/playback without losing sync even on a busy system.
  452.        Other features such as wave synthesis, MIDI and digital sig¡
  453.        nal processor (DSP) cannot be used. Also, recording and
  454.        playback at the same time is not possible. It currently
  455.        replaces VoxWare and was tested on several kernel versions
  456.        ranging from 1.0.9 to 1.2.1. Also, it is installable on UN*X
  457.        SysV386R3.2 systems."
  458.  
  459.   It can be found at  <http://www.cs.colorado.edu/~mccreary/tbeach>.
  460.  
  461.   Kim Burgaard (burgaard@daimi.aau.dk) has written a device driver and
  462.   utilities for the Roland MPU-401 MIDI interface. The Linux software
  463.   map entry gives this description:
  464.  
  465.        "A device driver for true Roland MPU-401 compatible MIDI
  466.        interfaces (including Roland SCC-1 and RAP-10/ATW-10). Comes
  467.        with a useful collection of utilities including a Standard
  468.        MIDI File player and recorder.
  469.  
  470.        Numerous improvements have been made since version 0.11a.
  471.        Among other things, the driver now features IRQ sharing pol¡
  472.        icy and complies with the new kernel module interface.
  473.        Metronome functionality, possibility for synchronizing e.g.
  474.        graphics on a per beat basis without losing precision,
  475.        advanced replay/record/overdub interface and much, much
  476.        more."
  477.  
  478.   It can be found at
  479.   <ftp://sunsite.unc.edu/pub/Linux/kernel/sound/mpu401-0.2.tar.gz>.
  480.  
  481.   Jaroslav Kysela and others have written an alternate sound driver for
  482.   the Gravis UltraSound Card. Information can be found at
  483.   <http://romeo.pf.jcu.cz/~perex/ultra>, the home page of the Linux
  484.   UltraSound Project.
  485.  
  486.   Another novel use for a sound card under Linux is as a modem for
  487.   amateur packet radio. The recent 2.1.x kernels include a driver that
  488.   works with SoundBlaster and Windows Sound System compatible sound
  489.   cards to implement 1200 bps AFSK and 9600 bps FSK packet protocols.
  490.   See the Linux AX25 HOWTO for details (I'm a ham myself, by the way --
  491.   callsign VE3ICH).
  492.  
  493.   3.3.  PC Speaker
  494.  
  495.   An alternate sound driver is available that requires no additional
  496.   sound hardware; it uses the internal PC speaker. It is mostly software
  497.   compatible with the sound card driver, but, as might be expected,
  498.   provides much lower quality output and has much more CPU overhead. The
  499.   results seem to vary, being dependent on the characteristics of the
  500.   individual loudspeaker. For more information, see the documentation
  501.   provided with the release.
  502.  
  503.   The current version is 1.1, and can be found at
  504.   <ftp://ftp.informatik.hu-berlin.de/pub/os/linux/hu-sound/>
  505.  
  506.   3.4.  Parallel Port
  507.  
  508.   Another option is to build a digital to analog converter using a
  509.   parallel printer port and some additional components. This provides
  510.   better sound quality than the PC speaker but still has a lot of CPU
  511.   overhead. The PC sound driver package mentioned above supports this,
  512.   and includes instructions for building the necessary hardware.
  513.  
  514.   4.  Installation
  515.  
  516.   Configuring Linux to support sound involves the following steps:
  517.  
  518.   1. Installing the sound card.
  519.  
  520.   2. Configuring and building the kernel for sound support.
  521.  
  522.   3. Creating the device files.
  523.  
  524.   4. Booting the Linux kernel and testing the installation.
  525.  
  526.   The next sections will cover each of these steps in detail.
  527.  
  528.   4.1.  Installing the Sound Card
  529.  
  530.   Follow the manufacturer's instructions for installing the hardware or
  531.   have your dealer perform the installation.
  532.  
  533.   Older sound cards usually have switch or jumper settings for IRQ, DMA
  534.   channel, etc; note down the values used. If you are unsure, use the
  535.   factory defaults. Try to avoid conflicts with other devices (e.g.
  536.   ethernet cards, SCSI host adaptors, serial and parallel ports) if
  537.   possible.
  538.   Usually you should use the same I/O port, IRQ, and DMA settings that
  539.   work under DOS. In some cases though (particularly with PnP cards) you
  540.   may need to use different settings to get things to work under Linux.
  541.   Some experimentation may be needed.
  542.  
  543.   4.2.  Configuring the Kernel
  544.  
  545.   When initially installing Linux you likely used a precompiled kernel.
  546.   These kernels usually do not provide sound support. It is best to
  547.   recompile the kernel yourself with the drivers you need. You may also
  548.   want to recompile the kernel in order to upgrade to a newer version or
  549.   to free up memory resources by minimizing the size of the kernel.
  550.  
  551.   The Linux Kernel HOWTO <http://sunsite.unc.edu/LDP/HOWTO/Kernel-
  552.   HOWTO.html> should be consulted for the details of building a kernel.
  553.   I will just mention here some issues that are specific to sound cards.
  554.  
  555.   If you have never configured the kernel for sound support before it is
  556.   a good idea to read all of the Readme files included with the kernel
  557.   sound drivers, particularly information specific to your card type.
  558.   The following documentation files can be found in the kernel sound
  559.   driver directory, usually installed in /usr/src/linux/drivers/sound:
  560.  
  561.   CHANGELOG         - description of changes in each release
  562.   COPYING           - copying and copyright restrictions
  563.   Readme            - latest and most important news
  564.   Readme.aedsp16    - information about Audio Excel DSP 16 sound card
  565.   Readme.cards      - notes on configuring specific cards
  566.   Readme.linux      - notes on installing separately release sound drivers
  567.   Readme.modules    - how to build driver as a loadable kernel module
  568.   Readme.v30        - new features in version 3.0 sound driver
  569.   experimental.txt  - notes on experimental features
  570.  
  571.   Follow the usual procedure for building the kernel. There are
  572.   currently three interfaces to the configuration process. A graphical
  573.   user interface that runs under X11 can be invoked using "make
  574.   xconfig". A menu-based system that only requires text displays is
  575.   available as "make menuconfig". The original method, using "make
  576.   config", offers a simple text-based interface.
  577.  
  578.   Special care must be taken when using "make xconfig" or "make
  579.   menuconfig". All Yes/No questions must be examined carefully. The
  580.   default answer provided by these commands is always No which is not
  581.   the proper one in all cases. In particular the "/dev/dsp and
  582.   /dev/audio support" (CONFIG_AUDIO) option should usually be enabled.
  583.  
  584.   In this document I will assume that you use the traditional command
  585.   line configuration process invoked using "make config", although the
  586.   process is similar in each case.
  587.  
  588.   There are also two different ways to configure sound. The first is the
  589.   "old" way (the only one offered prior to the 2.0.0 kernels). It uses a
  590.   standalone configuration program that is part of the sound driver.
  591.   This method works with most sound cards except the rare few that
  592.   require additional "low level" drivers (miroSOUND, AWE32, and AEDSP16
  593.   cards).
  594.  
  595.   The second is the "new" method which is better integrated with the
  596.   menu-based configuration used for the rest of the kernel. This one
  597.   doesn't work with sound cards that require a firmware download file.
  598.   This includes the PSS, SM Wave, AudioTrix Pro and TurtleBeach
  599.   Tropez/Maui cards. With these cards the old method has to be used.
  600.  
  601.   The "new" method is always used by "make xconfig". When using "make
  602.   menuconfig" you can select between the "old" and "new" methods in the
  603.   sound subscreen. When using "make config" you get the "old" method by
  604.   default. However if you have used the "new" method once, it will be
  605.   used by "make config" too. You can switch back to the "old" method by
  606.   running "make menuconfig" and by selecting the "old" one.
  607.  
  608.   The recommended method is to use "make menuconfig" together with the
  609.   "old" sound config method. Many sound configuration problems are
  610.   caused (at least partly) by incorrect use of the "new" method.
  611.  
  612.   It is also possible to build the sound driver as a kernel loadable
  613.   module. I recommend initially building the driver into the kernel.
  614.   Once it is tested and working you can explore using the kernel module
  615.   option.
  616.  
  617.   When you run make config, enable sound support by answering "y" to the
  618.   question
  619.  
  620.        Sound card support (CONFIG_SOUND) [M/n/y/?]
  621.  
  622.   At the end of the configuration questions a sound configuration
  623.   program will be compiled, run, and will then ask you what sound card
  624.   options you want. Be careful when answering these questions since
  625.   answering a question incorrectly may prevent some later ones from
  626.   being asked. For example, don't answer "yes" to the first question
  627.   (PAS16) if you don't really have a PAS16. Don't enable more cards than
  628.   you really need, since they just consume memory. Also some drivers
  629.   (like MPU-401) may conflict with your SCSI controller and prevent the
  630.   kernel from booting.
  631.  
  632.   I list here a brief description of each of the configuration dialog
  633.   options. Answer "y" (yes) or "n" (no) to each question. The default
  634.   answer is shown so that "Y/n/?" means "y" by default and "N/y/?"
  635.   means the default is "n". To use the default value, just hit Enter,
  636.   but remember that the default value isn't necessarily correct.
  637.  
  638.   Entering a question mark ("?") will produce a short descriptive
  639.   message describing that configuration option.
  640.  
  641.   Note also that all questions may not be asked. The configuration
  642.   program may disable some questions depending on the earlier choices.
  643.   It may also select some options automatically as well.
  644.  
  645.      Old configuration exists in /etc/soundconf. Use it Y/n/?
  646.         If you have previously compiled the kernel for sound support,
  647.         then the previous configuration can be saved. If you want to use
  648.         the previous setup, answer "y". If you are trying a different
  649.         configuration or have upgraded to a newer kernel, you should
  650.         answer "n" and go through the configuration process.
  651.  
  652.      ProAudioSpectrum 16 support Y/n/?
  653.         Answer "y" only if you have a Pro Audio Spectrum 16, ProAudio
  654.         Studio 16 or Logitech SoundMan 16. Don't answer 'y' if you have
  655.         some other card made by Media Vision or Logitech since they are
  656.         not PAS16 compatible.
  657.      SoundBlaster support Y/n/?
  658.         Answer "y" if you have an original SoundBlaster card made by
  659.         Creative Labs or a 100% hardware compatible clone (like the
  660.         Thunderboard or SM Games). If your card was in the list of
  661.         supported cards look at the card specific instructions in the
  662.         Readme.cards file before answering this question. For an unknown
  663.         card you may answer "y'"if the card claims to be SoundBlaster
  664.         compatible.
  665.  
  666.      Gravis Ultrasound support Y/n/?
  667.         Answer "y" if you have a GUS or GUS MAX. Answer "n" if you don't
  668.         have a GUS since the driver consumes a lot of memory.
  669.  
  670.      MPU-401 support (NOT for SB16) Y/n/?
  671.         Be careful with this question. The MPU-401 interface is
  672.         supported by almost all sound cards. However, some natively
  673.         supported cards have their own driver for MPU-401. Enabling the
  674.         MPU-401 option with these cards will cause a conflict. Also
  675.         enabling MPU-401 on a system that doesn't really have a MPU-401
  676.         could cause some trouble. If your card was in the list of
  677.         supported cards, look at the card specific instructions in the
  678.         Readme.cards file. It's safe to answer "y" if you have a true
  679.         MPU-401 MIDI interface card.
  680.  
  681.      6850 UART Midi support Y/n/?
  682.         It's safe to answer "n" to this question in all cases. The 6850
  683.         UART interface is very rarely used.
  684.  
  685.      PSS (ECHO-ADI2111) support Y/n/?
  686.         Answer "y" only if you have Orchid SW32, Cardinal DSP16 or some
  687.         other card based on the PSS chipset (AD1848 codec + ADSP-2115
  688.         DSP chip + Echo ESC614 ASIC CHIP).
  689.  
  690.      16 bit sampling option of GUS (not GUS MAX) Y/n/?
  691.         Answer "y" if you have installed the 16 bit sampling
  692.         daughtercard on your GUS. Answer "n" if you have a GUS MAX.
  693.         Enabling this option disables GUS MAX support.
  694.  
  695.      GUS MAX support Y/n/?
  696.         Answer "y" only if you have a GUS MAX.
  697.  
  698.      Microsoft Sound System support Y/n/?
  699.         Again think carefully before answering "y" to this question.
  700.         It's safe to answer "y" if you have the original Windows Sound
  701.         System card made by Microsoft or Aztech SG 16 Pro (or NX16 Pro).
  702.         Also you may answer "y" in case your card was not listed earlier
  703.         in this file. For cards having native support in VoxWare,
  704.         consult the card specific instructions in Readme.cards. Some
  705.         drivers have their own MSS support and enabling this option will
  706.         cause a conflict.
  707.  
  708.      Ensoniq Soundscape support Y/n/?
  709.         Answer "y" if you have a sound card based on the Ensoniq
  710.         SoundScape chipset. Such cards are being manufactured at least
  711.         by Ensoniq, Spea and Reveal (Reveal makes other cards also).
  712.  
  713.      MediaTriX AudioTriX Pro support Y/n/?
  714.         Answer "y" if you have the AudioTriX Pro.
  715.  
  716.      Support for MAD16 and/or Mozart based cards?
  717.         Answer "y" if your card has a Mozart (OAK OTI-601) or MAD16
  718.         (OPTi 82C928 or 82C929) audio interface chip. These chips are
  719.         currently quite common so it's possible that many no-name cards
  720.         have one of them. In addition the MAD16 chip is used in some
  721.         cards made by known manufacturers such as Turtle Beach (Tropez),
  722.         Reveal (some models) and Diamond (latest ones).
  723.  
  724.      Support for Crystal CS4232 based (PnP) cards Y/n/?
  725.         Answer "y" if you have a card based on the Crystal CS4232 chip
  726.         set.
  727.  
  728.      Support for Turtle Beach Wave Front (Maui, Tropez) synthesizers
  729.         Y/n/?"  Answer "y" if you have any of these cards.
  730.  
  731.      SoundBlaster Pro support Y/n/?
  732.         Enable this option if your card is a SoundBlaster Pro or
  733.         SoundBlaster 16. Enable it also with any SoundBlaster Pro
  734.         clones. Answering "n" saves some memory but "y" is the safe
  735.         alternative.
  736.  
  737.      SoundBlaster 16 support Y/n/?
  738.         Enable if you have a SoundBlaster 16 (including the AWE32).
  739.  
  740.      Audio Excel DSP 16 initialization support Y/n/?
  741.         Enable this if you have an Audio Excel DSP16 card. See the file
  742.         Readme.aedsp16 for more information.
  743.  
  744.   The configuration program then asks some questions about the higher
  745.   level services. It's recommended to answer "y" to each of these
  746.   questions. Answer "n" only if you know you will not need the option.
  747.  
  748.      /dev/dsp and /dev/audio support (usually required) Y/n/?
  749.         Answering "n" disables /dev/dsp and /dev/audio, the A/D and D/A
  750.         converter devices. Answer "y".
  751.  
  752.      MIDI interface support Y/n/?
  753.         Answering "n" disables /dev/midixx devices and access to any
  754.         MIDI ports using /dev/sequencer and /dev/music. This option also
  755.         affects any MPU-401 and/or General MIDI compatible devices.
  756.  
  757.      FM synthesizer (YM3812/OPL-3) support Y/n/?
  758.         Answer "y" here.
  759.  
  760.      /dev/sequencer support Y/n/?
  761.         Answering "n" disables /dev/sequencer and /dev/music
  762.  
  763.      Do you want support for the mixer of SG NX Pro ?
  764.         Answer "y" if you have a Sound Galaxy NX Pro sound card and want
  765.         support for its extended mixer functions.
  766.      Do you want support for the MV Jazz16 (ProSonic etc.) ?
  767.         Answer "y" if you have an MV Jazz16 sound card.
  768.  
  769.      Do you have a Logitech SoundMan Games Y/n/?
  770.         Answer "y" if you have a Logitech SoundMan Games sound card.
  771.  
  772.   After the above questions the configuration program prompts for the
  773.   card specific configuration information. Usually just a set of I/O
  774.   address, IRQ and DMA numbers are asked. With some cards the program
  775.   asks for some files to be used during initialization of the card.
  776.   These are used by cards which have a DSP chip or microprocessor which
  777.   must be initialized by downloading a program (microcode) file to the
  778.   card. In some cases this file is written to a .h file by the config
  779.   program and then included to the driver during compile. Again, read
  780.   the information in the file Readme.cards pertaining to your card type.
  781.  
  782.   At the end you will be prompted:
  783.  
  784.        The sound driver is now configured.
  785.        Save copy of this configuration to /etc/soundconf [Y/n/?]
  786.  
  787.   Normally you would enter "y" so that if you later need to recompile
  788.   the kernel you have the option of using the same sound driver
  789.   configuration.
  790.  
  791.   If you are upgrading from an older sound driver, make sure that the
  792.   files /usr/include/sys/soundcard.h and /usr/include/sys/ultrasound.h
  793.   are symbolic links to the corresponding files in /usr/include/linux,
  794.   or that they simply contain the lines #include <linux/soundcard.h> and
  795.   #include <linux/ultrasound.h>, respectively.
  796.  
  797.   You are now ready to compile and install the new kernel.
  798.  
  799.   4.3.  Creating the Device Files
  800.  
  801.   For proper operation, device file entries must be created for the
  802.   sound devices. These are normally created for you during installation
  803.   of your Linux system. A quick check can be made using the command
  804.   listed below. If the output is as shown (the date stamp will vary)
  805.   then the device files are almost certainly okay.
  806.  
  807.        % ls -l /dev/sndstat
  808.        crw-rw-rw-   1 root     root      14,   6 Apr 25  1995 /dev/sndstat
  809.  
  810.   Note that having the right device files there doesn't guarantee
  811.   anything on its own. The kernel driver must also be loaded or compiled
  812.   in before the devices will work (more on that later).
  813.  
  814.   In rare cases, if you believe the device files are wrong, you can
  815.   recreate them using the short shell script from the end of the file
  816.   Readme.linux in the directory /usr/src/linux/drivers/sound, running it
  817.   as user root. Alternatively, most Linux distributions have a
  818.   /dev/MAKEDEV script which can be used for this purpose.
  819.  
  820.   If you are using the PC speaker sound driver, read the documentation
  821.   that came with the package to determine if any device files need to be
  822.   created.
  823.  
  824.   4.4.  Booting Linux and Testing the Installation
  825.  
  826.   You should now be ready to boot the new kernel and test the sound
  827.   drivers. Follow your usual procedure for installing and rebooting the
  828.   new kernel (keep the old kernel around in case of problems, of
  829.   course).
  830.  
  831.   During booting, check for a message such as the following on powerup
  832.   (if they scroll by too quickly to read, you may be able to retrieve
  833.   them with the dmesg command):
  834.  
  835.        Sound initialization started
  836.        <Sound Blaster 16 (4.13)> at 0x220 irq 5 dma 1,5
  837.        <Sound Blaster 16> at 0x330 irq 5 dma 0
  838.        <Yamaha OPL3 FM> at 0x388
  839.        Sound initialization complete
  840.  
  841.   This should match your sound card type and jumper settings (if any).
  842.  
  843.   Note that the above messages are not displayed when using loadable
  844.   sound driver module (unless you enable it, e.g. using "insmod sound
  845.   trace_init=1).
  846.  
  847.   When the sound driver is linked into the kernel, the "Sound
  848.   initialization started" and "Sound initialization complete" messages
  849.   should be displayed. If they are not printed, it means that there is
  850.   no sound driver present in the kernel. In this case you should check
  851.   that you actually installed the kernel you compiled when enabling the
  852.   sound driver.
  853.  
  854.   If nothing is printed between the "Sound initialization started" and
  855.   the "Sound initialization complete" lines, it means that no sound
  856.   devices were detected. Most probably it means that you don't have the
  857.   correct driver enabled, the card is not supported, the I/O port is bad
  858.   or that you have a PnP card that has not been configured.
  859.  
  860.   The driver may also display some error messages and warnings during
  861.   boot. Watch for these when booting the first time after configuring
  862.   the sound driver.
  863.  
  864.   Next you should check the device file /dev/sndstat. Reading the sound
  865.   driver status device file should provide additional information on
  866.   whether the sound card driver initialized properly. Sample output
  867.   should look something like this:
  868.  
  869.   % cat /dev/sndstat
  870.   Sound Driver:3.5.4-960630 (Sat Jan 4 23:56:57 EST 1997 root,
  871.   Linux fizzbin 2.0.27 #48 Thu Dec 5 18:24:45 EST 1996 i586)
  872.   Kernel: Linux fizzbin 2.0.27 #48 Thu Dec 5 18:24:45 EST 1996 i586
  873.   Config options: 0
  874.  
  875.   Installed drivers:
  876.   Type 1: OPL-2/OPL-3 FM
  877.   Type 2: Sound Blaster
  878.   Type 7: SB MPU-401
  879.  
  880.   Card config:
  881.   Sound Blaster at 0x220 irq 5 drq 1,5
  882.   SB MPU-401 at 0x330 irq 5 drq 0
  883.   OPL-2/OPL-3 FM at 0x388 drq 0
  884.  
  885.   Audio devices:
  886.   0: Sound Blaster 16 (4.13)
  887.  
  888.   Synth devices:
  889.   0: Yamaha OPL-3
  890.  
  891.   Midi devices:
  892.   0: Sound Blaster 16
  893.  
  894.   Timers:
  895.   0: System clock
  896.  
  897.   Mixers:
  898.   0: Sound Blaster
  899.  
  900.   The command above can report some error messages. "No such file or
  901.   directory" indicates that you need to create the device files (see
  902.   section 4.3). "No such device" means that sound driver is not loaded
  903.   or linked into kernel. Go back to section 4.2 to correct this.
  904.  
  905.   If lines in the "Card config:" section of /dev/sndstat are listed
  906.   inside parentheses (such as "(SoundBlaster at 0x220 irq 5 drq 1,5)"),
  907.   it means that this device was configured but not detected.
  908.  
  909.   Now you should be ready to play a simple sound file. Get hold of a
  910.   sound sample file, and send it to the sound device as a basic check of
  911.   sound output, e.g.
  912.  
  913.        % cat endoftheworld >/dev/dsp
  914.        % cat crash.au >/dev/audio
  915.  
  916.   (Make sure you don't omit the ">" in the commands above).
  917.  
  918.   Note that, in general, using cat is not the proper way to play audio
  919.   files, it's just a quick check. You'll want to get a proper sound
  920.   player program (described later) that will do a better job.
  921.  
  922.   This command will work only if there is at least one device listed in
  923.   the audio devices section of /dev/sndstat. If the audio devices
  924.   section is empty you should check why the device was not detected.
  925.  
  926.   If the above commands return "I/O error", you should look at the end
  927.   of the kernel messages listed using the "dmesg" command. It's likely
  928.   that an error message is printed there. Very often the message is
  929.   "Sound: DMA (output) timed out - IRQ/DRQ config error?". The above
  930.   message means that the driver didn't get the expected interrupt from
  931.   the sound card. In most cases it means that the IRQ or the DMA channel
  932.   configured to the driver doesn't work. The best way to get it working
  933.   is to try with all possible DMAs and IRQs supported by the device.
  934.  
  935.   Another possible reason is that the device is not compatible with the
  936.   device the driver is configured for. This is almost certainly the case
  937.   when a supposedly "SoundBlaster (Pro/16) compatible" sound card
  938.   doesn't work with the SoundBlaster driver. In this case you should try
  939.   to find out the device your sound card is compatible with (by posting
  940.   to the comp.os.linux.hardware newsgroup, for example).
  941.  
  942.   Some sample sound files can be obtained from
  943.   <ftp://tsx-11.mit.edu/pub/linux/packages/sound/snd-data-0.1.tar.Z>
  944.  
  945.   Now you can verify sound recording. If you have sound input
  946.   capability, you can do a quick test of this using commands such as the
  947.   following:
  948.  
  949.        # record 4 seconds of audio from microphone
  950.        EDT% dd bs=8k count=4 </dev/audio >sample.au
  951.        4+0 records in
  952.        4+0 records out
  953.        # play back sound
  954.        % cat sample.au >/dev/audio
  955.  
  956.   Obviously for this to work you need a microphone connected to the
  957.   sound card and you should speak into it. You may also need to obtain a
  958.   mixer program to set the microphone as the input device and adjust the
  959.   recording gain level.
  960.  
  961.   If these tests pass, you can be reasonably confident that the sound
  962.   D/A and A/D hardware and software are working. If you experience
  963.   problems, refer to the next section of this document.
  964.  
  965.   4.5.  Troubleshooting
  966.  
  967.   If you still encounter problems after following the instructions in
  968.   the HOWTO, here are some things to check. The checks are listed in
  969.   increasing order of complexity. If a check fails, solve the problem
  970.   before moving to the next stage.
  971.  
  972.   4.5.1.  Step 1: Make sure you are really running the kernel you com¡
  973.   piled.
  974.  
  975.   You can check the date stamp on the kernel to see if you are running
  976.   the one that you compiled with sound support. You can do this with the
  977.   uname command:
  978.  
  979.   % uname -a
  980.   Linux fizzbin 2.0.0 #1 Tue Jun 4 16:57:55 EDT 1996 i386
  981.  
  982.   or by displaying the file /proc/version:
  983.  
  984.        % cat /proc/version
  985.        Linux version 2.0.0 (root@fizzbin) (gcc version 2.7.0) #1 Tue Jun 4 16:57:55 EDT 1996
  986.  
  987.   If the date stamp doesn't seem to match when you compiled the kernel,
  988.   then you are running an old kernel. Did you really reboot? If you use
  989.   LILO, did you re-install it (typically by running /etc/lilo/install)?
  990.   If booting from floppy, did you create a new boot floppy and use it
  991.   when booting?
  992.  
  993.   4.5.2.  Step 2: Make sure the kernel sound drivers are compiled in.
  994.  
  995.   The easiest way to do this is to check the output of "dev/sndstat" as
  996.   described earlier. If the output is not as expected then something
  997.   went wrong with the kernel configuration or build. Start the
  998.   installation process again, beginning with configuration and building
  999.   of the kernel.
  1000.  
  1001.   4.5.3.  Step 3: Did the kernel detect your sound card during booting?
  1002.  
  1003.   Make sure that the sound card was detected when the kernel booted. You
  1004.   should have seen a message on bootup. If the messages scrolled off the
  1005.   screen, you can usually recall them using the dmesg command:
  1006.  
  1007.        % dmesg
  1008.  
  1009.   or
  1010.  
  1011.        % tail /var/adm/messages
  1012.  
  1013.   If your sound card was not found then something is wrong. Make sure it
  1014.   really is installed. If the sound card works under DOS then you can be
  1015.   reasonably confident that the hardware is working, so it is likely a
  1016.   problem with the kernel configuration. Either you configured your
  1017.   sound card as the wrong type or wrong parameters, or your sound card
  1018.   is not compatible with any of the Linux kernel sound card drivers.
  1019.  
  1020.   One possibility is that your sound card is one of the "compatible"
  1021.   type that requires initialization by the DOS driver. Try booting DOS
  1022.   and loading the vendor supplied sound card driver. Then soft boot
  1023.   Linux using Control-Alt-Delete. Make sure that card I/O address, DMA,
  1024.   and IRQ settings for Linux are the same as used under DOS. Read the
  1025.   Readme.cards file from the sound driver source distribution for hints
  1026.   on configuring your card type.
  1027.  
  1028.   If your sound card is not listed in this document, it is possible that
  1029.   the Linux drivers do not support it. You can check with some of the
  1030.   references listed at the end of this document for assistance.
  1031.  
  1032.   4.5.4.  Step 4: Can you read data from the dsp device?
  1033.  
  1034.   Try reading from the /dev/audio device using the dd command listed
  1035.   earlier in this document. The command should run without errors.
  1036.  
  1037.   If it doesn't work, then chances are that the problem is an IRQ or DMA
  1038.   conflict or some kind of hardware incompatibility (the device is not
  1039.   supported by Linux or the driver is configured for a wrong device).
  1040.  
  1041.   A remote possibility is broken hardware. Try testing the sound card
  1042.   under DOS, if possible, to eliminate that as a possibility.
  1043.  
  1044.   4.5.5.  When All Else Fails
  1045.  
  1046.   If you still have problems, here are some final suggestions for things
  1047.   to try:
  1048.  
  1049.   ╖  carefully re-read this HOWTO document
  1050.  
  1051.   ╖  read the references listed at the end of this document, especially
  1052.      Hannu Savolainen's web pages and the relevant kernel source Readme
  1053.      files
  1054.  
  1055.   ╖  post a question to one of the comp.os.linux or other Usenet
  1056.      newsgroups (comp.os.linux.hardware is a good choice; because of the
  1057.      high level of traffic in these groups it helps to put the string
  1058.      "sound" in the subject header for the article so the right experts
  1059.      will see it)
  1060.  
  1061.   ╖  Using a Web/Usenet search engine with an intelligently selected
  1062.      search criteria can give very good results quickly. One such choice
  1063.      is <http://www.altavista.digital.com>
  1064.  
  1065.   ╖  try using the latest Linux kernel (but only as a last resort, the
  1066.      latest development kernels can be unstable)
  1067.  
  1068.   ╖  send mail to the author of the sound driver
  1069.  
  1070.   ╖  send mail to the author of the Sound HOWTO
  1071.  
  1072.   ╖  fire up emacs and type Esc-x doctor :-)
  1073.  
  1074.   5.  Applications Supporting Sound
  1075.  
  1076.   I give here a sample of the types of applications that you likely want
  1077.   if you have a sound card under Linux. You can check the Linux Software
  1078.   Map, Internet archive sites, and/or files on your Linux CD-ROM for
  1079.   more up to date information.
  1080.  
  1081.   As a minimum, you will likely want to obtain the following sound
  1082.   applications:
  1083.  
  1084.   ╖  audio file format conversion utility (e.g. Sox)
  1085.  
  1086.   ╖  mixer utility (e.g. aumix or xmix)
  1087.  
  1088.   ╖  digitized file player/recorder (e.g. play or wavplay)
  1089.  
  1090.   ╖  MOD file player (e.g. tracker)
  1091.  
  1092.   ╖  MIDI file player (e.g. playmidi)
  1093.  
  1094.   There are text-based as well as GUI-based versions of most of these
  1095.   tools. There are also some more esoteric applications (e.g. speech
  1096.   synthesis and recognition) that you may wish to try.
  1097.  
  1098.   6.  Answers To Frequently Asked Questions
  1099.  
  1100.   This section answers some of the questions that have been commonly
  1101.   asked on the Usenet news groups and mailing lists.
  1102.  
  1103.   Answers to more questions can also be found at the OSS sound driver
  1104.   web page.
  1105.  
  1106.   6.1.  What are the various sound device files?
  1107.  
  1108.   These are the most "standard" device file names, some Linux
  1109.   distributions may use slightly different names.
  1110.  
  1111.      /dev/audio
  1112.         normally a link to /dev/audio0
  1113.  
  1114.      /dev/audio0
  1115.         Sun workstation compatible audio device (only a partial
  1116.         implementation, does not support Sun ioctl interface, just u-law
  1117.         encoding)
  1118.  
  1119.      /dev/audio1
  1120.         second audio device (if supported by sound card or if more than
  1121.         one sound card installed)
  1122.  
  1123.      /dev/dsp
  1124.         normally a link to /dev/dsp0
  1125.  
  1126.      /dev/dsp0
  1127.         first digital sampling device
  1128.  
  1129.      /dev/dsp1
  1130.         second digital sampling device
  1131.  
  1132.      /dev/mixer
  1133.         normally a link to /dev/mixer0
  1134.  
  1135.      /dev/mixer0
  1136.         first sound mixer
  1137.  
  1138.      /dev/mixer1
  1139.         second sound mixer
  1140.  
  1141.      /dev/music
  1142.         high-level sequencer interface
  1143.  
  1144.      /dev/sequencer
  1145.         low level MIDI, FM, and GUS access
  1146.  
  1147.      /dev/sequencer2
  1148.         normally a link to /dev/music
  1149.  
  1150.      /dev/midi00
  1151.         1st raw MIDI port
  1152.  
  1153.      /dev/midi01
  1154.         2nd raw MIDI port
  1155.  
  1156.      /dev/midi02
  1157.         3rd raw MIDI port
  1158.  
  1159.      /dev/midi03
  1160.         4th raw MIDI port
  1161.  
  1162.      /dev/sndstat
  1163.         displays sound driver status when read
  1164.  
  1165.   The PC speaker driver provides the following devices:
  1166.  
  1167.      /dev/pcaudio
  1168.         equivalent to /dev/audio
  1169.  
  1170.      /dev/pcsp
  1171.         equivalent to /dev/dsp
  1172.  
  1173.      /dev/pcmixer
  1174.         equivalent to /dev/mixer
  1175.  
  1176.   6.2.  How can I play a sound sample?
  1177.  
  1178.   Sun workstation (.au) sound files can be played by sending them to the
  1179.   /dev/audio device. Raw samples can be sent to /dev/dsp. This will
  1180.   generally give poor results though, and using a program such as play
  1181.   is preferable, as it will recognize most file types and set the sound
  1182.   card to the correct sampling rate, etc.
  1183.  
  1184.   Programs like wavplay or vplay (in the snd-util package) will give
  1185.   best results with WAV files. However they don't recognize Microsoft
  1186.   ADPCM compressed WAV files. Also older versions of play (from the Lsox
  1187.   package) doesn't work well with 16 bit WAV files.
  1188.  
  1189.   The splay command included in the snd-util package can be used to play
  1190.   most sound files if proper parameters are entered manually in the
  1191.   command line.
  1192.  
  1193.   6.3.  How can I record a sample?
  1194.  
  1195.   Reading /dev/audio or /dev/dsp will return sampled data that can be
  1196.   redirected to a file. A program such as vrec makes it easier to
  1197.   control the sampling rate, duration, etc. You may also need a mixer
  1198.   program to select the appropriate input device.
  1199.  
  1200.   6.4.  Can I have more than one sound card?
  1201.  
  1202.   With the current sound driver it's possible to have several
  1203.   SoundBlaster, SoundBlaster/Pro, SoundBlaster16, MPU-401 or MSS cards
  1204.   at the same time on the system. Installing two SoundBlasters is
  1205.   possible but requires defining the macros SB2_BASE, SB2_IRQ, SB2_DMA
  1206.   and (in some cases) SB2_DMA2 by editing local.h manually. It's also
  1207.   possible to have a SoundBlaster at the same time as a PAS16.
  1208.  
  1209.   With the newer 2.0.x kernels that configure sound using make config,
  1210.   instead of local.h, you need to edit the file
  1211.   /usr/include/linux/autoconf.h.  After the section containing the
  1212.   lines:
  1213.  
  1214.        #define SBC_BASE 0x220
  1215.        #define SBC_IRQ (5)
  1216.        #define SBC_DMA (1)
  1217.        #define SB_DMA2 (5)
  1218.        #define SB_MPU_BASE 0x0
  1219.        #define SB_MPU_IRQ (-1)
  1220.  
  1221.   add these lines (with values appropriate for your system):
  1222.  
  1223.        #define SB2_BASE 0x330
  1224.        #define SB2_IRQ (7)
  1225.        #define SB2_DMA (2)
  1226.        #define SB2_DMA2 (2)
  1227.  
  1228.   The following drivers don't permit multiple instances:
  1229.  
  1230.   ╖  GUS (driver limitation)
  1231.  
  1232.   ╖  MAD16 (hardware limitation)
  1233.  
  1234.   ╖  AudioTrix Pro (hardware limitation)
  1235.  
  1236.   ╖  CS4232 (hardware limitation)
  1237.  
  1238.   6.5.  Error: No such file or directory for sound devices
  1239.  
  1240.   You need to create the sound driver device files. See the section on
  1241.   creating device files. If you do have the device files, ensure that
  1242.   they have the correct major and minor device numbers (some older CD-
  1243.   ROM distributions of Linux may not create the correct device files
  1244.   during installation).
  1245.  
  1246.   6.6.  Error: No such device for sound devices
  1247.  
  1248.   You have not booted with a kernel containing the sound driver or the
  1249.   I/O address configuration doesn't match your hardware. Check that you
  1250.   are running the newly compiled kernel and verify that the settings
  1251.   entered when configuring the sound driver match your hardware setup.
  1252.  
  1253.   6.7.  Error: No space left on device for sound devices
  1254.  
  1255.   This can happen if you tried to record data to /dev/audio or /dev/dsp
  1256.   without creating the necessary device file. The sound device is now a
  1257.   regular file, and has filled up your disk partition. You need to run
  1258.   the script described in the Creating the Device Files section of this
  1259.   document.
  1260.  
  1261.   This may also happen with Linux 2.0 and later if there is not enough
  1262.   free RAM on the system when the device is opened. The audio driver
  1263.   requires at least two pages (8k) of contiguous physical RAM for each
  1264.   DMA channel. This happens sometimes in machines with less than 16M of
  1265.   RAM or which have been running for very long time. It may be possible
  1266.   to free some RAM by compiling and running the following C program
  1267.   before trying to open the device again:
  1268.  
  1269.        main() {
  1270.          int i;
  1271.          char mem[500000];
  1272.          for (i = 0; i < 500000; i++)
  1273.            mem[i] = 0;
  1274.          exit(0);
  1275.        }
  1276.  
  1277.   6.8.  Error: Device busy for sound devices
  1278.  
  1279.   Only one process can open a given sound device at one time. Most
  1280.   likely some other process is using the device in question. One way to
  1281.   determine this is to use the fuser command:
  1282.  
  1283.        % fuser -v /dev/dsp
  1284.        /dev/dsp:             USER       PID ACCESS COMMAND
  1285.                              tranter    265 f....  tracker
  1286.  
  1287.   In the above example, the fuser command showed that process 265 had
  1288.   the device open. Waiting for the process to complete or killing it
  1289.   will allow the sound device to be accessed once again. You should run
  1290.   the fuser command as root in order to report usage by users other than
  1291.   yourself.
  1292.  
  1293.   6.9.  I still get device busy errors!
  1294.  
  1295.   According to Brian Gough, for the SoundBlaster cards which use DMA
  1296.   channel 1 there is a potential conflict with the QIC-02 tape driver,
  1297.   which also uses DMA 1, causing "device busy" errors. If you are using
  1298.   FTAPE, you may have this driver enabled. According to the FTAPE-HOWTO
  1299.   the QIC-02 driver is not essential for the use of FTAPE; only the
  1300.   QIC-117 driver is required. Reconfiguring the kernel to use QIC-117
  1301.   but not QIC-02 allows FTAPE and the sound-driver to coexist.
  1302.  
  1303.   6.10.  Partial playback of digitized sound file
  1304.  
  1305.   The symptom is usually that a sound sample plays for about a second
  1306.   and then stops completely or reports an error message about "missing
  1307.   IRQ" or "DMA timeout". Most likely you have incorrect IRQ or DMA
  1308.   channel settings. Verify that the kernel configuration matches the
  1309.   sound card jumper settings and that they do not conflict with some
  1310.   other card.
  1311.  
  1312.   Another symptom is sound samples that "loop". This is usually caused
  1313.   by an IRQ conflict.
  1314.  
  1315.   6.11.  There are pauses when playing MOD files
  1316.  
  1317.   Playing MOD files requires considerable CPU power. You may have too
  1318.   many processes running or your computer may be too slow to play in
  1319.   real time. Your options are to:
  1320.  
  1321.   ╖  try playing with a lower sampling rate or in mono mode
  1322.  
  1323.   ╖  eliminate other processes
  1324.  
  1325.   ╖  buy a faster computer
  1326.  
  1327.   ╖  buy a more powerful sound card (e.g. Gravis UltraSound)
  1328.  
  1329.   If you have a Gravis UltraSound card, you should use one of the mod
  1330.   file players written specifically for the GUS (e.g. gmod).
  1331.  
  1332.   6.12.  Compile errors when compiling sound applications
  1333.  
  1334.   The version 1.0c and earlier sound driver used a different and
  1335.   incompatible ioctl() scheme. Obtain newer source code or make the
  1336.   necessary changes to adapt it to the new sound driver. See the sound
  1337.   driver Readme file for details.
  1338.  
  1339.   Also ensure that you have used the latest version of soundcard.h and
  1340.   ultrasound.h when compiling the application. See the installation
  1341.   instructions at beginning of this text.
  1342.  
  1343.   6.13.  SEGV when running sound binaries that worked previously
  1344.  
  1345.   This is probably the same problem described in the previous question.
  1346.  
  1347.   6.14.  What known bugs or limitations are there in the sound driver?
  1348.  
  1349.   See the Readme and CHANGELOG files included with the sound driver
  1350.   kernel source.
  1351.  
  1352.   6.15.  Where are the sound driver ioctls() etc. documented?
  1353.  
  1354.   These are partially documented in the Hacker's Guide to VoxWare,
  1355.   currently available in draft form. The latest version is draft 2, and
  1356.   can be found on  <ftp://nic.funet.fi/pub/Linux/ALPHA/sound/>. Note
  1357.   that this directory is "hidden" and will not appear in directory
  1358.   listings. If you "cd" to the directory and use the FTP "dir" command,
  1359.   the files are there.
  1360.  
  1361.   At time of writing new documentation was becoming available on the
  1362.   4Front Technologies Web site.
  1363.  
  1364.   Another source of information is the Linux Multimedia Guide, described
  1365.   in the references section.
  1366.  
  1367.   6.16.  What CPU resources are needed to play or record without pauses?
  1368.  
  1369.   There is no easy answer to this question, as it depends on:
  1370.  
  1371.   ╖  whether using PCM sampling or FM synthesis
  1372.  
  1373.   ╖  sampling rate and sample size
  1374.  
  1375.   ╖  which application is used to play or record
  1376.  
  1377.   ╖  Sound Card hardware
  1378.  
  1379.   ╖  disk I/O rate, CPU clock speed, cache size, etc.
  1380.  
  1381.   In general, any 386 machine should be able to play samples or FM
  1382.   synthesized music on an 8 bit sound card with ease.
  1383.  
  1384.   Playing MOD files, however, requires considerable CPU resources. Some
  1385.   experimental measurements have shown that playing at 44kHz requires
  1386.   more than 40% of the speed of a 486/50 and a 386/25 can hardly play
  1387.   faster than 22 kHz (these are with an 8 bit card sound such as a
  1388.   SoundBlaster). A card such as the Gravis UltraSound card performs more
  1389.   functions in hardware, and will require less CPU resources.
  1390.  
  1391.   These statements assume the computer is not performing any other CPU
  1392.   intensive tasks.
  1393.  
  1394.   Converting sound files or adding effects using a utility such as sox
  1395.   is also much faster if you have a math coprocessor (or CPU with on
  1396.   board FPU). The kernel driver itself does not do any floating point
  1397.   calculations, though.
  1398.  
  1399.   6.17.  Problems with a PAS16 and an Adaptec 1542 SCSI host adaptor
  1400.  
  1401.   (the following explanation was supplied by seeker@indirect.com)
  1402.  
  1403.   Linux only recognizes the 1542 at address 330 (default) or 334, and
  1404.   the PAS only allows the MPU-401 emulation at 330. Even when you
  1405.   disable the MPU-401 under software, something still wants to conflict
  1406.   with the 1542 if it's at its preferred default address. Moving the
  1407.   1542 to 334 makes everyone happy.
  1408.  
  1409.   Additionally, both the 1542 and the PAS-16 do 16-bit DMA, so if you
  1410.   sample at 16-bit 44 KHz stereo and save the file to a SCSI drive hung
  1411.   on the 1542, you're about to have trouble. The DMAs overlap and there
  1412.   isn't enough time for RAM refresh, so you get the dread ``PARITY ERROR
  1413.   - SYSTEM HALTED'' message, with no clue to what caused it. It's made
  1414.   worse because a few second-party vendors with QIC-117 tape drives
  1415.   recommend setting the bus on/off times such that the 1542 is on even
  1416.   longer than normal. Get the SCSISEL.EXE program from Adaptec's BBS or
  1417.   several places on the internet, and reduce the BUS ON time or increase
  1418.   the BUS OFF time until the problem goes away, then move it one notch
  1419.   or more further. SCSISEL changes the EEPROM settings, so it's more
  1420.   permanent than a patch to the DOS driver line in CONFIG.SYS, and will
  1421.   work if you boot right into Linux (unlike the DOS patch). Next problem
  1422.   solved.
  1423.  
  1424.   Last problem - the older Symphony chipsets drastically reduced the
  1425.   timing of the I/O cycles to speed up bus accesses. None of various
  1426.   boards I've played with had any problem with the reduced timing except
  1427.   for the PAS-16. Media Vision's BBS has SYMPFIX.EXE that's supposed to
  1428.   cure the problem by twiddling a diagnostic bit in Symphony's bus
  1429.   controller, but it's not a hard guarantee. You may need to:
  1430.  
  1431.   ╖  get the motherboard distributor to replace the older version bus
  1432.      chip,
  1433.  
  1434.   ╖  replace the motherboard, or
  1435.  
  1436.   ╖  buy a different brand of sound card.
  1437.  
  1438.   Young Microsystems will upgrade the boards they import for around $30
  1439.   (US); other vendors may be similar if you can figure out who made or
  1440.   imported the motherboard (good luck). The problem is in ProAudio's bus
  1441.   interface chip as far as I'm concerned; nobody buys a $120 sound card
  1442.   and sticks it in a 6MHz AT. Most of them wind up in 25-40MHz 386/486
  1443.   boxes, and should be able to handle at least 12MHz bus rates if the
  1444.   chips are designed right. Exit soapbox (stage left).
  1445.  
  1446.   The first problem depends on the chipset used on your motherboard,
  1447.   what bus speed and other BIOS settings, and the phase of the moon.
  1448.   The second problem depends on your refresh option setting (hidden or
  1449.   synchronous), the 1542 DMA rate and (possibly) the bus I/O rate. The
  1450.   third can be determined by calling Media Vision and asking which
  1451.   flavor of Symphony chip is incompatible with their slow design. Be
  1452.   warned, though - 3 of 4 techs I talked to were brain damaged. I would
  1453.   be very leery of trusting anything they said about someone else's
  1454.   hardware, since they didn't even know their own very well.
  1455.  
  1456.   6.18.  Is it possible to read and write samples simultaneously?
  1457.  
  1458.   Due to hardware limitations, this is not possible with most sound
  1459.   cards. Some newer cards do support it. See the section on
  1460.   "bidirectional mode" in the Hacker's Guide to Voxware for more
  1461.   information.
  1462.  
  1463.   6.19.  My SB16 is set to IRQ 2, but configure does not allow this
  1464.   value.
  1465.  
  1466.   On '286 and later machines, the IRQ 2 interrupt is cascaded to the
  1467.   second interrupt controller. It is equivalent to IRQ 9.
  1468.  
  1469.   6.20.  Are the SoundBlaster AWE32 or SoundBlaster16 ASP supported?
  1470.  
  1471.   In the past, Creative Labs was not willing to release programming
  1472.   information for these cards. They have since changed their policy and
  1473.   an AWE driver is now included in the Linux 2.1.x kernels.
  1474.  
  1475.   6.21.  If I run Linux, then boot DOS, I get errors and/or sound appli¡
  1476.   cations do not work properly.
  1477.  
  1478.   This happens after a soft reboot to DOS. Sometimes the error message
  1479.   misleadingly refers to a bad CONFIG.SYS file.
  1480.  
  1481.   Most of the current sound cards have software programmable IRQ and DMA
  1482.   settings. If you use different settings between Linux and MS-
  1483.   DOS/Windows, this may cause problems. Some sound cards don't accept
  1484.   new parameters without a complete reset (i.e. cycle the power or use
  1485.   the hardware reset button).
  1486.  
  1487.   The quick solution to this problem it to perform a full reboot using
  1488.   the reset button or power cycle rather than a soft reboot (e.g. Ctrl-
  1489.   Alt-Del).
  1490.  
  1491.   The correct solution is to ensure that you use the same IRQ and DMA
  1492.   settings with MS-DOS and Linux (or not to use DOS :-).
  1493.  
  1494.   6.22.  Problems running DOOM under Linux
  1495.  
  1496.   Users of the port of ID software's game DOOM for Linux may be
  1497.   interested in these notes.
  1498.  
  1499.   For correct sound output you need version 2.90 or later of the sound
  1500.   driver; it has support for the real-time "DOOM mode".
  1501.  
  1502.   The sound samples are 16-bit. If you have an 8-bit sound card you can
  1503.   still get sound to work using one of several programs available in
  1504.   <ftp://sunsite.unc.edu/pub/Linux/games/doom>.
  1505.  
  1506.   If performance of DOOM is poor on your system, disabling sound (by
  1507.   renaming the file sndserver) may improve it.
  1508.  
  1509.   By default DOOM does not support music (as in the DOS version). The
  1510.   program musserver will add support for music to DOOM under Linux. It
  1511.   can be found at  <ftp://pandora.st.hmc.edu/pub/linux/musserver.tgz>.
  1512.  
  1513.   6.23.  How can I reduce noise picked up by my sound card?
  1514.  
  1515.   Using good quality shielded cables and trying the sound card in
  1516.   different slots may help reduce noise. If the sound card has a volume
  1517.   control, you can try different settings (maximum is probably best).
  1518.  
  1519.   Using a mixer program you can make sure that undesired inputs (e.g.
  1520.   microphone) are set to zero gain.
  1521.  
  1522.   Some sound cards are simply not designed with good shielding and
  1523.   grounding and are prone to noise pickup.
  1524.  
  1525.   Finally, on my system I found that the kernel command line option no-
  1526.   hlt reduces the noise level. This tells the kernel not to use the halt
  1527.   instruction when running the idle process loop. You can try this
  1528.   manually when booting, or set it up using the command append="no-hlt"
  1529.   in your LILO configuration file.
  1530.  
  1531.   6.24.  I can play sounds, but not record.
  1532.  
  1533.   If you can play sound but not record, try these steps:
  1534.  
  1535.   ╖  use a mixer program to select the appropriate device (e.g.
  1536.      microphone)
  1537.  
  1538.   ╖  use the mixer to set the input gains to maximum
  1539.  
  1540.   ╖  If you can, try to test sound card recording under MS-DOS to
  1541.      determine if there is a hardware problem
  1542.  
  1543.   Sometimes a different DMA channel is used for recording than for
  1544.   playback. In this case the most probable reason is that the recording
  1545.   DMA is set up incorrectly.
  1546.  
  1547.   6.25.  My "compatible" sound card only works if I first initialize
  1548.   under MS-DOS.
  1549.  
  1550.   In most cases a "SoundBlaster compatible" card will work better under
  1551.   Linux if configured with a driver other than the SoundBlaster one.
  1552.   Most sound cards claim to be compatible (e.g. "16 bit SB Pro
  1553.   compatible" or "SB compatible 16 bit") but usually this SoundBlaster
  1554.   mode is just a "hack" provided for DOS games compatibility. Most cards
  1555.   have a 16 bit native mode which is likely to be supported by recent
  1556.   Linux versions (2.0.1 and later).
  1557.  
  1558.   Only with some (usually rather old) cards is it necessary to try to
  1559.   get them to work in the SoundBlaster mode. The only newer cards that
  1560.   are the exception to this rule are the Mwave-based cards.
  1561.  
  1562.   6.26.  My 16-bit SoundBlaster "compatible" sound card only works in
  1563.   8-bit mode under Linux.
  1564.  
  1565.   16-bit sound cards described as SoundBlaster compatible are really
  1566.   only compatible with the 8-bit SoundBlaster Pro. They typically have a
  1567.   16-bit mode which is not compatible with the SoundBlaster 16 and not
  1568.   compatible with the Linux sound driver.
  1569.  
  1570.   You may be able to get the card to work in 16-bit mode by using the
  1571.   MAD16 or MSS/WSS driver.
  1572.  
  1573.   6.27.  Where can I find sound applications for Linux?
  1574.  
  1575.   Here are some good archive sites to search for Linux specific sound
  1576.   applications:
  1577.  
  1578.   ╖  <ftp://sunsite.unc.edu:/pub/Linux/kernel/sound/>
  1579.  
  1580.   ╖  <ftp://sunsite.unc.edu:/pub/Linux/apps/sound/>
  1581.  
  1582.   ╖  <ftp://tsx-11.mit.edu:/pub/linux/packages/sound/>
  1583.  
  1584.   ╖  <ftp://nic.funet.fi:/pub/Linux/util/sound/>
  1585.  
  1586.   ╖  <ftp://nic.funet.fi:/pub/Linux/xtra/snd-kit/>
  1587.  
  1588.   ╖  <ftp://nic.funet.fi:/pub/Linux/ALPHA/sound/>
  1589.  
  1590.   6.28.  Can the sound driver be compiled as a loadable module?
  1591.  
  1592.   With recent kernels the sound driver is supported as a kernel loadable
  1593.   module.
  1594.  
  1595.   See the files /usr/src/linux/drivers/sound/Readme.modules and
  1596.   /usr/src/linux/Documentation/modules.txt (or /usr/src/linux/README)
  1597.   for details.
  1598.  
  1599.   6.29.  Can I use a sound card to replace the system console beep?
  1600.  
  1601.   Try the oplbeep program, found at
  1602.   <ftp://sunsite.unc.edu/pub/Linux/apps/sound/oplbeep-alpha.tar.gz>
  1603.  
  1604.   Another variant is the beep program found at
  1605.   <ftp://sunsite.unc.edu/pub/Linux/kernel/patches/misc/modreq_beep.tgz>
  1606.  
  1607.   The modutils package has an example program and kernel patch that
  1608.   supports calling an arbitrary external program to generate sounds when
  1609.   requested by the kernel.
  1610.  
  1611.   Alternatively, with some sound cards you can connect the PC speaker
  1612.   output to the sound card so that all sounds come from the sound card
  1613.   speakers.
  1614.  
  1615.   6.30.  What is VoxWare?
  1616.  
  1617.   The kernel sound drivers support several different Intel-based Unix
  1618.   compatible operating systems, and can be obtained as a package
  1619.   separate from the Linux kernel. Up until February 1996 the author had
  1620.   called the software "VoxWare". Unfortunately this name has been
  1621.   registered by VoxWare Incorporated, and can not be used. The new name
  1622.   of the driver is OSS/Free.
  1623.  
  1624.   The Open Sound System (OSS) is a commercially available kernel sound
  1625.   driver for various Unix systems, sold by 4Front Technologies. The free
  1626.   version, known as OSS/Free will continue to be made freely available
  1627.   for Linux systems.
  1628.  
  1629.   Other names you may come across that have been used in the past to
  1630.   refer to the same sound driver are TASD (Temporarily Anonymous Sound
  1631.   Driver) and USS (Unix Sound System).
  1632.  
  1633.   For more information see the 4Front Technologies Web page at
  1634.   <http://www.4front-tech.com/>. I wrote a review of OSS/Linux in the
  1635.   June 1997 issue of Linux Journal.
  1636.  
  1637.   6.31.  Are Plug and Play sound card supported?
  1638.  
  1639.   Full Plug and Play support should be coming in Linux version 2.1. In
  1640.   the mean time there are a number of workarounds for getting Plug and
  1641.   Play sound cards to work.
  1642.   If you have a newer Pentium system with a Plug and Play BIOS, it
  1643.   should take care of configuring the cards for you. Make sure that you
  1644.   configure the Linux sound driver to use the same I/O address, IRQ, and
  1645.   DMA channel parameters as the BIOS.
  1646.  
  1647.   There is a package of Plug and Play tools for Linux that can be used
  1648.   to set up the card. It can be found at Red Hat's Web site
  1649.   <http://www.redhat.com/> (it may also be included in your Linux
  1650.   distribution).
  1651.  
  1652.   If you use the card under Windows95, you can use the device manager to
  1653.   set up the card, then soft boot into Linux using the LOADLIN program.
  1654.   Make sure Windows95 and Linux use the same card setup parameters.
  1655.  
  1656.   If you use the card under DOS, you can use the icu utility that comes
  1657.   with SoundBlaster16 PnP cards to configure it under DOS, then soft
  1658.   boot into Linux using the LOADLIN program. Again, make sure DOS and
  1659.   Linux use the same card setup parameters.
  1660.  
  1661.   The commercial OSS sound driver has support for the SoundBlaster16 PnP
  1662.   sound card. You can purchase this driver from 4Front Technologies.
  1663.  
  1664.   6.32.  Sox/Play/Vplay reports "invalid block size 1024"
  1665.  
  1666.   A change to the sound driver in version 1.3.67 broke some sound player
  1667.   programs which (incorrectly) checked that the result from the
  1668.   SNDCTL_DSP_GETBLKSIZE ioctl was greater than 4096. The utilities
  1669.   included in the latest snd-util-3.x.tar.gz package (at
  1670.   <ftp://ftp.4front-tech.com/ossfree>.) now handle this properly. The
  1671.   latest sound driver versions have also been fixed to avoid allocating
  1672.   fragments shorter than 4096 bytes which solves this problem with old
  1673.   utilities.
  1674.  
  1675.   6.33.  Why does the sound driver have its own configuration program?
  1676.  
  1677.   The sound driver supports many different configuration parameters.
  1678.   The configure program included with the sound driver checks for many
  1679.   dependencies between parameters. The tools used to configure the
  1680.   kernel don't support this level of functionality.
  1681.  
  1682.   That said, the latest kernels do optionally allow using the standard
  1683.   kernel configuration tools with the sound driver (see the earlier
  1684.   section on "Configuring the Kernel".
  1685.  
  1686.   6.34.  The mixer settings are reset whenever I load the sound driver
  1687.   module
  1688.  
  1689.   You can build the sound driver as a loadable module and use kerneld to
  1690.   automatically load and unload it. This can present one problem -
  1691.   whenever the module is reloaded the mixer settings go back to their
  1692.   default values. For some sound cards this can be too loud (e.g.
  1693.   SoundBlaster16) or too quiet. Markus Gutschke (gutschk@uni-
  1694.   muenster.de) found this solution. Use a line in your /etc/conf.modules
  1695.   file such as the following:
  1696.  
  1697.        options sound dma_buffsize=65536 && /usr/bin/setmixer igain 0 ogain 0 vol 75
  1698.  
  1699.   This causes your mixer program (in this case setmixer) to be run
  1700.   immediately after the sound driver is loaded. The dma_buffsize
  1701.   parameter is just a dummy value needed because the option command
  1702.   requires a command line option. Change the line as needed to match
  1703.   your mixer program and gain settings.
  1704.  
  1705.   If you have compiled the sound driver into your kernel and you want to
  1706.   set the mixer gains at boot time you can put a call to your mixer
  1707.   program in a system startup file such as /etc/rc.d/rc.local.
  1708.  
  1709.   6.35.  Only user root can record sound
  1710.  
  1711.   By default the script in Readme.linux that creates the sound device
  1712.   files only allows the devices to be read by user root. This is to plug
  1713.   a potential security hole. In a networked environment, external users
  1714.   could conceivably log in remotely to a Linux PC with a sound card and
  1715.   microphone and eavesdrop. If you are not worried about this, you can
  1716.   change the permissions used in the script.
  1717.  
  1718.   With the default setup, users can still play sound files. This is not
  1719.   a security risk but is a potential for nuisance.
  1720.  
  1721.   6.36.  Is the sound hardware on the IBM ThinkPad supported?
  1722.  
  1723.   Information on how to use the mwave sound card on an IBM ThinkPad
  1724.   laptop computer under Linux can be found at
  1725.   <http://www.screamin.demon.co.uk/>.
  1726.  
  1727.   7.  References
  1728.  
  1729.   If you have a sound card that supports a CD-ROM or SCSI interface, the
  1730.   Linux SCSI HOWTO and the Linux CD-ROM HOWTO have additional
  1731.   information that may be useful to you.
  1732.  
  1733.   The Sound Playing HOWTO describes how to play various types of sound
  1734.   and music files under Linux.
  1735.  
  1736.   The Ultrasound Plug'n'play Mini-HOWTO describes how to get a plug and
  1737.   play Gravis Ultrasound card working under Linux.
  1738.  
  1739.   The Linux SoundBlaster 16 PnP Mini-HOWTO describes how to get a plug
  1740.   and play SoundBlaster 16 card working under Linux.
  1741.  
  1742.   The Linux SoundBlaster AWE64 PnP Mini-HOWTO describes how to get a
  1743.   plug and play SoundBlaster AWE64 card working under Linux.
  1744.  
  1745.   There is an old document called the Hacker's Guide to VoxWare,
  1746.   available from  <ftp://nic.funet.fi/pub/Linux/ALPHA/sound/>. Most of
  1747.   the information in there has been superseded by the documents at
  1748.   <http://www.4front-tech.com/pguide>, but the section on /dev/sequencer
  1749.   may still be useful.
  1750.  
  1751.   The following FAQs are regularly posted to the Usenet newsgroup
  1752.   news.announce as well as being archived at
  1753.   <ftp://rtfm.mit.edu/pub/usenet/news.answers>:
  1754.  
  1755.   ╖  PCsoundcards/generic-faq (Generic PC Soundcard FAQ)
  1756.  
  1757.   ╖  PCsoundcards/soundcard-faq (comp.sys.ibm.pc.soundcard FAQ)
  1758.  
  1759.   ╖  PCsoundcards/gravis-ultrasound/faq (Gravis UltraSound FAQ)
  1760.  
  1761.   ╖  audio-fmts/part1 (Audio file format descriptions)
  1762.  
  1763.   ╖  audio-fmts/part2 (Audio file format descriptions)
  1764.  
  1765.   The FAQs also list several product specific mailing lists and archive
  1766.   sites. The following Usenet news groups discuss sound and/or music
  1767.   related issues:
  1768.  
  1769.   ╖  alt.binaries.sounds.* (various groups for posting sound files)
  1770.  
  1771.   ╖  alt.binaries.multimedia (for posting Multimedia files)
  1772.  
  1773.   ╖  alt.sb.programmer (Soundblaster programming topics)
  1774.  
  1775.   ╖  comp.multimedia (Multimedia topics)
  1776.  
  1777.   ╖  comp.music (Computer music theory and research)
  1778.  
  1779.   ╖  comp.sys.ibm.pc.soundcard.* (various IBM PC sound card groups)
  1780.  
  1781.   A Web site dedicated to multimedia can be found at
  1782.   <http://viswiz.gmd.de/MultimediaInfo/>. Creative Labs has a Web site
  1783.   at  <http://www.creaf.com/>. MediaTrix has a Web site at
  1784.   <http://www.mediatrix.com/>.
  1785.  
  1786.   The Linux mailing list has a number of "channels" dedicated to
  1787.   different topics, including sound. To find out how to join, send a
  1788.   mail message with the word "help" as the message body to
  1789.   majordomo@vger.rutgers.edu. These mailing lists are not recommended
  1790.   for questions on sound card setup etc., they are intended for
  1791.   development related discussion.
  1792.  
  1793.   As mentioned several times before, the kernel sound driver includes a
  1794.   number of Readme files containing useful information about the sound
  1795.   card driver. These can typically be found in the directory
  1796.   /usr/src/linux/drivers/sound.
  1797.  
  1798.   The author of the kernel sound driver, Hannu Savolainen, can be
  1799.   contacted by email at hannu@voxware.pp.fi. He also has a World-Wide
  1800.   Web site at  <http://personal.eunet.fi/pp/voxware>. The Web site is
  1801.   the best source for finding out the latest status of supported sound
  1802.   cards, known problems, and bug fixes.
  1803.  
  1804.   Information on OSS, the commercial sound driver for Linux and other
  1805.   Unix compatible operating systems, can be found on the 4Front
  1806.   Technologies Web page at  <http://www.4front-tech.com/>.
  1807.  
  1808.   The Linux Software Map (LSM) is an invaluable reference for locating
  1809.   Linux software. Searching the LSM for keywords such as sound is a good
  1810.   way to identify applications related to sound hardware. The LSM can be
  1811.   found on various anonymous FTP sites, including
  1812.   <ftp://sunsite.unc.edu/pub/Linux/docs/LSM/>.
  1813.  
  1814.   The Linux Documentation Project has produced several books on Linux,
  1815.   including Linux Installation and Getting Started. These are freely
  1816.   available by anonymous FTP from major Linux archive sites or can be
  1817.   purchased in hardcopy format.
  1818.  
  1819.   Finally, a shameless plug: If you want to learn a lot more about
  1820.   multimedia under Linux (especially CD-ROM and sound card applications
  1821.   and programming), check out my book Linux Multimedia Guide, ISBN
  1822.   1-56592-219-0, published by O'Reilly and Associates. As well as the
  1823.   original English version, French and Japanese translations are now in
  1824.   print. For details, call 800-998-9938 in North America or check the
  1825.   Web page  <http://www.ora.com/catalog/multilinux/noframes.html> or my
  1826.   home page  <http://www.pobox.com/~tranter>.
  1827.  
  1828.